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WEB CAT.TgMTHVP npr 7HITECTrTRE AND USES THEREOF 

5 Backcrro und of ^ the Invent i on 

^ ■ - - • 

The invention begins with an intention to- create a Java 
visual table widget (vTable) with Internet capability on 
the Web . browser. It can be used by the programmers who 

10 need a table widget written . in Java to organize data 

presentation. vTable is a programmable layout manager that 
supports data presentation in two dimensional grids, rows, 
columns and cells . vTable adopts model-view GUI paradigm,' 
such that for each view object, there is a model object 

15 ■- controlling its contents. There can be multiple views 
associated with a. single, model. So once" the model's 
contents changed, all of the related views will be 
automatically refreshed with the new contents. 



20 



25 



When it was completed, we felt a real Internet application 
that builds upon the visual table would serve to enhance 
the widget's interfaces and features. The application • of 
Web based Calendar came naturally, since every calendar 
view uses two dimensional, table . - Jigsaw puzzle was also in 
consideration, but was ruled out for it has no practical 
usage . 



The calendar started off as a Web based personal organizer. 
It provides daily events and appointments scheduling. To 

30 make our Web Calendar stands out from the others. ^ we 

created the calendar-applet ("Capplet") architecture to 
support the multimedia event contents distribution and 
online registration. ' It features '"client side event 
specification and the association between "capplet™ and 

35 event. To leverage on the Web's interconnection nature, we 

created group concept which represents a. collection of 
individual canlendars. it allows the sharing and 

coordinating of events and schedules among a group of 
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users. With the inclusion of group features, the Web 
calendar has grown " from a personal organizer to a 
scheduling and calendaring groupware. 

In addition, as we build the calendar applet, we had 
enhanced our Java GUT foundation library to support our GUI 
needs. This- includes specialized Layout managers, Panels, 
List controls and miscellaneous components . Layout manager 
organize its components geographical locations.. Panel is 
a container that . is contained . within a container. All of 
these enhancements are necessary for the Web Calendar GUI 
and are not provided by the Java language Abstract 
Windowing Toolkit (AWT) . 

The scope of the invention covers: 1) Java personal 
organizer, 2) Internet scheduling and calendar groupware, 
3) Calendar event with multimedia effect, 4) Joint multiple 
calendars view, 5) Open calendar architecture that is ready, 
to run any Java applet, SY Invocation method for programs 
with display panels and 7) Internet transaction done 
directly through calendar events. 

The Internet and World Wide Web 

Jnternet . " 

The Internet is the name for a group of worldwide 
information resources. The roots of the Internet lie in a' 
collection of computer networks that were developed in the 
1970s. They started with a network called the Arpanet that 
was sponsored by the United States Department of Defense. 
The original Arpanet has long since been expanded . and 
replaced, and today its descendent form the global backbone 
of what we call the Internet. 

■ It would be a mistake however to think of the Internet as 
a computer network', or even a group * of computer networks 
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connected to one another. The computer networks are simply 
the medium that carries the huge resource of practical and 
en D oyable information. The Internet allows millions of 
people all over the world to communicate and to share. It 
is a people-oriented society. 

Internet has a slew of services : Text file, Telnet session, 
Gopher, Usenet news group, File Transfer Protocol and the 
latest and greatest World Wide Web, each with either " 
specialized information contents or specialized network 
functions . 

World Wide Web (WWW) 

The Web, one of Internet's many resources, was originally 
developed in Switzerland, at the CERN research center. The 
idea was to create a way for the CERN physicists to share 
their work and to use community information. This idea was 
soon embraced within the, Internet as a general mechanism 
for accessing information and services. 

Like many other Internet resources; ^ the Web uses a 
client /server system. Users use a client program called a 
browser act as a window into the Web . t From the point of 
Web, everything in the universe consists of either 
documents or links. Thus the job of a browser is to read 
documents and to follow whatever links users select. A 
browser knows how to access just about every service and 
resource on the Internet, especially it knows how to 
connect to WWW servers that offer public hypertext 
documents . 



is 



In the language of the Web, a hypertext 'document 
something that contains data and possibly, links to other 
documents. What makes the Web so powerful is that a link 
might go to any type of Internet resource. It is flexible 
and convenient to use . 
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The Internet Protocols 

The protocols that Internet hosts use to communicate among 
themselves are key components of the net. For the WWW, 
HTTP is the most important of- these communication 
protocols.. All documents on the WWW are referenced through 
a URL. And each URL begins with the name of the protocol, 
HTTP, that is used to find that document. A Web browser 
must have the HTTP capability built-in. 
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30 



Java 



Java is a language developed by Sun with the intent to meet 
the challenge of application development in the context of 
15 heterogeneous network -wide distributed environments. And 

the paramount among these challenges is the secure delivery 
of applications that consume the minimum- of system 
resources, can run on any hardware and software platform, 
and can be dynamically extended. 

20 . " -. ... 

The massive growth of the Internet and the World-Wide Web 
leads us to a completely new way of looking at development 
and distribution of software. To live in the world of 
electronic commerce and distribution, the Java language 
supports secure, high-performance, and. highly robust 
application development on multiple platforms in 
heterogeneous, distributed networks. ~ 

Operating : on multiple platforms in heterogeneous networks 
invalidates, the traditional schemes of binary distribution, 
release, upgrade, patch, and so on. To survive in this 
jungle, the Java language has to be architectural-neutral, 
portable, arid dynamically adaptable..^ 

35 - To ensure the programmers can flourish within their 
software development environment, the Java language system 
that emerged to meet these needs is simple, so it can be 
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easily programmed by most . developers , familiar, so that 
current developers can easily learn the Java language, 
objected oriented, to fit into distributed client -server 
applications, multithreaded, for high performance in 
applications that need to perform multiple concurrent 
activities, and interpreted, for maximum portability and 
dynamic capabilities. . 

Java vs. Procedural . Languages 

At -a fundamental level, procedure languages ' are designed 
first to provide programmers with a framework for issuing 
commands for the computer" to execute (hence the term 
"procedural") and second to allow programmers to organize 
and manipulate data. Depending on the language, how 
intuitively a procedural language on these two features 
very quite a bit. For examples, COBOL, FORTRAN and C are 
all procedural languages, but each has a specialized area 
and cannot be interchanged. 

An object-oriented language like Java is designed first to 
allow programmers to define the objects that make up the 
program and data they contain, and second to' define the 
code that makes up the program. - . ^ 

Many programmers are now using C++ or languages like Object 
Pascal, Perl 5.0, and Objective C -What-, these languages 
have in common is that they are^ hybrid languages, or 
procedural' languages with object-oriented extensions. 
These languages make it possible for programmers to use 
objects within their programs, but they allow-and in many 
cases, required-to use procedural code to accomplish certain 
tasks . " . 

Java vs. Other Object-Oriented Languages 



A pure object-oriented language entails all data in the 
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language is represented in the form of objects. in 
SmallTalk, which is. a pure object-oriented . language, every 
aspect of the language is object- or message-based and all 
data typles, simple or complex, are object classes. 



as 



Java implements the basic C simple data types, such 
integer, characters and floating-point' numbers, outside the 
object system, but deals with everything else as objects. 
. And this language design enables Java to avoid many of the 
10 * performance pitfalls found in a purely object-oriented 
language. In all other ways, Java -is a pure 

object-oriented language. All program code and data reside 
within objects and classes. ' 

15 Applet 

An applet is a small Java program that ''is automatically 
downloaded from a Web site and run within your Web browser 
in response to instructions to do so contained within the 
20 Web page you are viewing. , 

Java Enabled Browser 

There are three different types of Web browser, ordinary 
25 Web browser, Java-capable Web browser and native Java' Web 

browser. Ordinary Web. browser is not' capable of handling 
applets. Users of this kind of browser would not get the 
results produced by the applets. 

30 A Java-capable browser, such as Netscape/Navigator 2.0 -and 

later releases, is a browser that supports Java applets. 
This kind of browser provides a display area for the applet 
either in the browser window which displays the Web in the 
same way that the, browser displays images on a page, or in 

35. a pop-up window which displays only the applet. The applet 

can use this display area however it sees fit, using the 
area to display buttons and other user interface controls 



• 
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or to display graphics and animation. 

HotJava, the native Java Web browser, itself was written in 
Java. Applets running in Hot Java can have much more 
5 c 9 ntrol over the browser's user interface environment, and 

the browser can be extended to support new media formats 
and protocols through the use of Java code. There are 
definite boundaries between the, ,C code in which 1 the- 
Netscape browser was written and the Java code of the 
10 applets that the browser runs. 

Java and Other Platforms 

Although Sun intends to directly support only a select 
15 group of platforms, it has taken steps to ensure that Java 

will eventually be ported to every platform where there is 
interest to do so. Sun has made the source code to the JDK 
freely available for non- commercial use . This triggered. a 
number of efforts to port Java to different platforms 
20 including Linux, Next, and Amiga, in addition to Window 95, 

Window NT and Sun's Solaris, Macintosh, HP/UX, JBM/AIX, and 
SGI/Irix. These effort is much necessary to truly make 
. Java applets, transparent to all the ^operating environments 
that are connected to the Internet. - 
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Prior Art 

Sparc Work Calendar Tool 

SparcWork Calendar Tool is a calendar schedule keeper 
developed by Sun. On one hand," it serves as a personal 
organizer, capable of scheduling and. reminding users of 
their appointments.' On. the other hand, as a groupware, it 
has the capability of sharing schedule information work 
group users . 

Like every other scheduling software, Calendar Tool is, 
strictly text based. There's no multimedia effect, no 
joint multiple calendars view, no collaborative features, 
and it cannot, connect to the Internet services such, as e- 
mail and linkage to other Web resources. Above all, like 
most of the other vendor scheduler/organizer, it functions 
only within Sun's proprietary operating system. 
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Brief Description of Ficfurpg 

Figure l: The Capplet'" Architecture. ' 

This figure illustrates the general Web Calendar 
architecture that includes a Calendar Base, and all 
. the calendar views that are built upon the base! The 
Calendar Base supports Capplet™ - event association 
and execution process of Java applet within the 
calendar environment. 

Figure 2 : Stages of Capplet™ - . 

This figure illustrates the stages of Capplet™/ from 
independent applet with a special mission, to an event 
associated Capplet™ called "Capplet™ instance" and the 
invoked "Capplet™ instance" within our Web Calendar 
, environment . < 

Figure 3: A Web Calendar implemented as Java applets. 

This figure illustrates a Web Calendar, itself 
implemented in Java as an applet, that can be included 
-in an HTML document and can be retrieved from any Java 
enabled Web browser. in contrast to a Web Calendar 
implemented in HTML, the applet calendar provides 
distributed process and network load balanced benefits 
where HTML approach is lacking. The server provides 
schedule storage and group hierarchy information that 
feeds the client calendar interactively via the 
applets . 

Figure 4: Calendar Event , Event Action and Capplets™. 

Each scheduled event is defined as a Calendar Event , 
which in turn contains a list of Actions such as mail 
alert, beep ( alert or pop-up alert. J In general. 
Actions describe what the user wants the Calendar to 
do when the scheduled event arrives . Every event 
Action has the facility to associate with a specialty 
Capplet™ and have the Calendar trigger the Action (in 
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turn the Capplet™ automatically or manually. 

Figure 5 : Applet Running Context . 

This figure illustrates the layers of our approach to 
facilitate the. running of any applet within our Web 
Calendar. The Applet Shell provides every applet 
execution conditions needed by the Capplets 1 *. This 
approach made the Web Calendar an open and extensible 
platform. 

Figure 6: A consolidated view of multiple Web calendars. 

This figure illustrates our approach to achieve the 
capability of viewing and editing multiple calendars. 
Users can view their own calendar along with other 

15 calendars within a single calendar view (daily, 

multiple days, weekly, monthly or yearly) . Via the 
menu push buttons, users have the choice to 
include /exclude calendars into/from the calendar view, 
in order to create any desired calendar combinations. 

20 This provides users the ability to coordinate 

schedules among a group of calendars. 

Figure 7: A program invocation method with panel dimension 
specification. 

25 In order to invoke a program in a specific location on 

screen, and in a panel with specified dimensions, the 
user can pursue the : following steps. First, highlight 
the program icon with a mouse point and click. 
Second, select a location on^ the screen where the 

30 running window will fix its left-top corner and, press 

down the mouse button. Third, drag the mouse diagonal 
to the desired lower right corner. Fourth, release 
the mouse button. These steps will ^trigger the 
highlighted program and run- it in a window with 

35 defined left-top and lower-right corners. 



Figure 8 : Internet Transaction linked to Calendar event . 
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While a surfer of Web- Calendar checking out the Box 
Office event schedules, the surfer sees an interesting 
performance and wants to book a seat. All the surfer 
needs to do is to bring the mouse pointer to the event 
5 text and click the • mouse button. This triggers a 

Registration Capplet™ associated with . - that 
performance. By filling out the primary, secondary 
preference and commit, the surfer instructs the 
Capplet™ to send the information to the server for a 

10 transaction processing. The surfer will then be 

responded with either a rejection or a confirmation 
and' a reference number by the server. NOTE: Web 
Calendar has. two sides of users; the calendar events 
publisher (e.g. Museum, Corporations, Sports, College 

15 courses, ...etc.) and the Web surfers (e.g. Consumer, 

students, ... etc.). 
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Detail ed Description of Invention 

Terminology Definitions 

5 Web- Calendar : a calendar system that runs in a Internet" 

• server/browser environment. 

Calendar base: the key calendar component' that manages 
scheduled events and controls the execution of actions 
10 associated with an event . 

Capplet™: a specialized Java program that runs within a 
Web calendar, to provide multimedia effect or event related 
transactions for -scheduled events. For example, 
15 A Capplet 11 " that sings the happy birthday song while 

displaying a graphic of animated cake candles and 

balloons. 

A Capplet™ that • sings' Christmas choir and displays 
animated snowman or Santa Claus . 
20 A Capplet™ that shows today's weather in a multimedia 

graphical display. 

A Capplet™ that . sends- an e-mail to the users. 

A Capplet™ that schedules future events on behalf of 

the user. 

25' ' - . . 

A Capplet™ that is associated with an event or schedule can 
be forwarded to designated recipients for pleasure or for 
busines functions. 

30 Calendar view: a view that displays calendar events and 

their related information with a time perspective. A 
calendar often has four types of views: monthly, multiple 
days, weekly, daily and yearly views. Each view has a time 
scope. For example, a monthly view with' a scope. of July, 

35 1996 shows events in July, 1996. A weekly view has a scope 

of seven days. A daily view shows events in 24 -hour slots. 
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Panel: a graphical display area within a view.. 

Event: an entity associated with a time. An event has at 
least three components: (1) starting time, (2) ending time 
5 and (3) a description. For example, 

Appointment with dentist at 7:00pm, July 2, 19 96. 

John's birthday on July 4, 1996. 

Java conference from June 3, 1996 to June 7, 1996. 
Dinner appointment at 7:00pm, June 8, 1996. 
Project deadline on July 10, 1996 



HTML (Hypertext Markup Language) : It is the language in 
which the Web documents are written. HTML has the 
following features: 
15 Document formatting. 

The ability to include hyperlinks which" point to other 
Web documents or services on computer systems, all over 
the Internet. 

Embed graphical images and clickable image maps with 
hot spots to take users to various places depending on 
where in the image users clicked. 



20 



Multithreading: The ability to run multiple threads 
concurrently. Each thread can be thought of as a separate 
25 mini-program that gets started by an application and runs 

in parallel to it. Java program often uses several threads 
handling various activities such as tracking the mouse 
position, updating the position of on-screen graphical 
objects, or simply keeping time. s . 

30 

Object Oriented: A buzzword these days. It is used to 
describe languages, styles of programming, user interfaces 
and just about anything else. - Conceptually, object 
programming is often described by example in terms of the 
35 real-world objects (cars, people, houses, computers, etc.) 

by using software objects to simulate * them in an 
object-oriented language. 
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Protocol: A messaging mechanism that is understood by both 
ends of the communication line. 

Concurrency: Multiple processes or threads running within 
5 the same time slot in a time sharing manner. However each 

process or thread thinks it has the whole CPU to, itself. 
This makes belief that all' of the processes are running 
concurrently. - 

10 GUI (Graphical User Interface) : A general term for all 

window based front -end widgets. All GUI's make use of 
graphics, on a bitmapped video display. Graphics provides 
better utilization of screen real estate, a virtually rich 
environment for conveying information, and the possibility 

15 of WYSWYG (what you see is what you get) video' display of 

graphics and formatted text prepared for a ' printed' 
document . ' 

Model-View Paradigm: A methodology in GUI programming 
20 technique. It entails all displayed data contents be 

controlled by an independent model object.. There is no 
limit of how many views can be associated with a model. 
The model has the intelligence of detecting a data content 
change, and thereby triggering refresh actions for all the 
2 5 related views. Sometimes this intelligence is built in yet 

a third object called Controller. The ideas is to 
de-couple display functions and application functions, 
following a clean and easy to maintain programming 
practice. 



30 



We say that an event occurs if the current time is between 
the starting time and the ending time of the event. 



35 



We say that an " event appears in a view if either the 
starting time or the ending time of the event falls within 
the scope of the view. 
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We say that a view is enabled if the calendar user chooses 
it through user interface. 

This invention provides the base Capplet'" architecture 
5 recited in Figure 1, which allows multiple Java programs to 

run simultaneously in a Web calendar. 

Within our Java implemented Web calendar base architecture, 
- Java applet can be associated with any calendar event ". 
Each calendar event, in addition to the applet association, 
can trigger multiple actions such as e-mail, pop-up alert,' 
beeping. Applets can be triggered simultaneously in the 
daily, multiple, days, weekly and monthly views, either in 
the cells or in pop-up windows. 

The Web calendar shown in the basic Capplet 1 " architecture 
(Figure 1) can either be implemented as a Java applet, or 
as an HTML document that runs within a Web browser (See 
Figure 3). In this specification, we describe the 
implementation of a Java calendar platform applet, which 
emphasizes on the client side's capabilities and 
flexibility as opposed to HTML's sole reliance on the 
server side process. 

25 The Web calendar applet, a platform running either in the 

Internet or any Intranet environment, organizes and manages, 
event schedules for individuals or working groups. This 
platform is responsible of keeping and showing the private 
and/or public event schedules. Events information are 
displayed in one of the four calendar views (monthly, 
weekly, daily, multiple days and yearly) , and is maintained 
in the Web server database . - 

A Java program that can run- within a Web calendar is named 
35 a Capplet'". - Once a Capplet'" is associated to an event, it., 

becomes ready to be triggered. The pair [Capplet 1 ", event] 
is referred to as a Capplet™ instance (See Figure 2) . 



20 



30 
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Multiple Capplet ,M instances may. be . created with the same 
Capplet' 



10 



25 



There is no limit regarding the number of Capplet™ 
instances and the number of Capplet s w that can be 
associated with an event. 

The Capplet™ in a Capplet™ instance may be activated in one 
of the, following five ways:' 



When the event occurs . 

When a user triggers it. ^ 
When a view in which the event appears is enabled. 
When a second Capplet™ activates it. 
15 When the Capplet™ is associated to an event (i.e., 

when the Capplet™ instance is created) . 

. An activated Capplet™ can access the information related to 
its associated event, such as retrieving the event 
20 description or inserting a new event' into the user's 

schedule. Multiple Capplets™ can be activated and run in 
a multithreaded fashion (simultaneously) . One panel in the 
enabled view may be assigned to a running Capplet'*. A 
Capplet'" can also be a background process without a view. 



Association Process 



There is an programming interface within the Capplet'" 
architecture to facilitate Capplet™ and event association. 

30 The result object is called a Capplet™ instance . There can 

be as many Capplet™ instances as the user desires per 
Capplet™. Each Capplet™ instance carries an event id to 
maintain its uniqueness within the calendar system. Notice 
that the Capplet™ instance is persistent, so that user does 

35 not have to re-associate the instance, even after it has 

" been activated or even after the whole Web Calendar has 

been restarted. 
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Within each event, there can be as many actions as the user 
desires. Each action, carrying an unique action id, can be 
associated with a Capplet™ shown in Figure 4. m order to 
lend the multimedia animation and interaction to otherwise 
5 mundane calendar platform, we incorporated a basic Capplet'" 

architecture into the calendar platform applet we 
provided the following five design components : 

l. Common Capplet™ interface. " 

10 2. The process to associate a Capplet'- to an event. 

3. Capplet 1 " execution environment. 

4. Capplet*" triggering mechanisms. 

5. Capplet 1 " plug- in procedure. 

15 Executi on Environment 

In order to run multiple Capplets™ simultaneously,, the 

calendar applet prepares one environment for each Capplet™ 

and performs the following: 

1. Create a new thread. 
20 2. Execute the init ( ) method with the thread. 

3. ■ Check whether the Capplet™ has a panel by calling 

getConfigPaneK) . If yes, add the panel to the view. 
'4. Execute the start method with the thread. 

5. To exit, execute the stop ( ) method 
25 • ' ■ ' 

API 

/* 

* Create a schedule item for a certain date. 

* @ date - the date when the -event is scheduled 
30 * @ detail - the detail of the event 

• */ - ... 

public final class CalEvent extends eRow { 

public CalEvent (String . owner. Date date, String 
detail) 

35 throws IllegalAccessException 

{ 
} 
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// 

// Modify the privacy setting of this, event. 

// The possible values are w U"ser, "G"roup 

// and "World. Only the owner of the event 

5 // can change the privacy value of the event. 

// Otherwise, an, exception will be thrown. 

// ' 3 

public setPrivacy (String value); throws 

IllegalAccessException. { 

io Y . : 

// 

// Check to see if a particular, user is, the 
// owner of this event. 

// ^ 
15 public isOwner (String, user) { 

) ' 
1 public set (String, key, Object value) { 

} 

public Object get (String key) { 
20 } 

// - - 

//To determine if a date/time falls within 
J // this event's time period. This facilitates 
// the use of multiple days event. 

25 // 

public boolean inside (WMDate date) { 

} 

" } ' 
30 // 

// A container class which holds and manages a list 
// of action objects associated with a specific 
// calendar event - schedule . Each action object in 
// the list is associated with an action type. 
35 // 

public final class ActionList extends HashTable { 
public Action get {String act ionType ) { 
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. } , 

public Object put (Object key, object value)' { 

5 . } ' • 

// The Action class is a container class which 
// holds information and means to execute 
// Capplet™ or Agent. 

// : 



public final class Action 'extends Object { 

// Create an Action object of a certain 
15 // action type. 

public Action (String actionType) { 



20 



25 



// Get the type of this action, 
public final String getActionType ( ) { 

// The event that is associated with this 
// action. 

public final CalEvent getEvent() { 
} 



// Is this an alert type of action? 
public boolean isAlertO { 
30 } 

// Set the time in seconds when this action 
// should take place before the actual start 
// time. The default value is 0. Only an 
35 // ^tion of ALERT type would be useful in 

/ / this case . 

public final void setAlertBef ore ( long seconds) { 
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} ' 

// Set the DOMAIN in which this action should 
// take place., Capplets™ that are designed to 
-5 // run on CLIENT domain may not suitable for 

// SERVER domain. 

public final void setLocation { int location) { 

) 

10 public boolean isClientDomain ( ) { 

.} 

public boolean isServerDomain ( ) { . .. 

} 

15 

public void initO { 

} 

public void start {) { 

} , " . 

20 public void stop ( ) { - 

} * - . 



25 } 



30 



public Capplet 1 " getCapplet 1 " ( ) 
} 



This invention provides a process to run any Java applet on 
our Web Calendar. In other words, we claim the open ended 
characteristics of the overall calendar architecture. 



The applet that can be associated with our Web Calendar 
events and run within our calendar context need not conform 
to any proprietary application programming interface (API) 
requirements. Just following the standard Java applet API 
35 is enough to be able to associate with our calendar event 

and run within our calendar. 



WO 98/13753 

PCT/US97/I7389 



10 



15 



20 



25 



■21- 



Java applets have its own common interface, which is 
defied a an abstract class called Appiet . ln order " B 
run an applet within a Web calendar, the calendar platfo™ 
applet must provide applet context for each applet 
approach is; to adopt an applet shell, which will serve .s 
an applet context (See Figure 5). 

For each applet to run, there are certain functions that 
the applet must call to prepare itself before runni„ 3 an d 
coordinate computer resource with other proces.es while 
running. Our applet shell that is' integrated with the Web 
Calendar provides these functions so that any applet can 
run within the Web Calendar views, instead of running in 
its own applet viewer independently. 



API : 



class CappletShell extends Panel implements Capplet™ 

Applet applet = null; 

Capplet™ Shell (Applet applet) { 
super ( ) ; 

this, applet = applet'; 
setLayout (new BorderLayout ( ) ) ; 
add ("Center", this. applet) ; - 

} 



public void setStub.(AppletStub stub) { 
applet. setstub (stub) ; 

30 } 

public void initCapplet™(CalEvent event, Hashtable 
param) { 

applet .init () ; 

35 } 



public void start () { 
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applet . start ( ) ; 

-} 

public void stopO { 
applet . stop ( ) ; 

} 



Common Interface 



Like Java applet™, every Capplet™ must conform to. a common, 
interface. A Java interface is defined as follows: 

public interface Capplet { 
15 public void initCapplet 1 " (CalEvent event, Hashtable 

parameters) ; " 1 

public void start {); 
.public void stopO ; 

} , 

20 

public interface Conf igurableCapplet"" extends. Capplet 1 " { 
public java.awt .Panel get Conf igPanel (java . awt . Frame 

parent Frame) ; ^ 
25 public java.util. Hashtable get Conf igParameters () ; 

The object with the interface of Configurable Capplet'" 
provides a panel and the system will then prepare a applet 
context for it. 

30 

This invention provides a process to facilitate the viewing 
' and editing of multiple calendars, using a single calendar 
view (See Figure 6) . While the users are' looking at a 
single calendar view (daily, multiple days, weekly, 
35 monthly, yearly or tasks), the schedule information may 

consist of one or many Web calendar (s) . As the user moves 
the mouse pointer across the calendar view, the owner 
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information pertinent to the pointed calendar schedule will 
be displayed at the. bottom of the calendar view. 

in its embodiment, end-users can choose a collection of 
5 calendars to be displayed in a single calendar view. For 

each calendar selected and downloaded form the 
internet/intranet, there is a corresponding ■ menu push 
button displayed below the calendars. Via these menu 
buttons, users have the option to dynamically create- any 
10 calendar combinations from the currently downloaded 

calendars . 

The Web Calendar also provides the editing capability of 
multiple calendars to specific users. These users are 
given the- authority by the calendar owners to update their 
calendar schedules, during their absence or inability to 
update the calendars themselves. 



15 
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API 



// Copyright' (c) 1995-1998 WebMan Technologies Inc 
// 

// Code segment demonstrating Timecruiser- calendar 
management . 
25 // 

// Get all the names of the user selected calendars. 
// Hidden calendars included, 
protected Vector getAllCalNames ( ) { 
return (Vector ) allCalNames.. clone (> 

) - 



// Get all the names of the currently visible calendars 
protected Vector getVisibleCalNames ( ) { 
35 return (Vector ) visibleCalNames . clone () • 

} 



PCT/US97/17389 

WO 98/13753 

-24- 

// Add a series of calendars to be displayed, 
public void addCalendars (Vector vec) { 
if ( yec — null ) { 

return; - 

5 } ■ " - ' 

f or ( Enumeration enum=vec . elements () ; 

enum. hasMoreElements ( ) ; ) { 

String name = enum.nextElement { ) . toString ( ) 
10 addCalendar (name, false) ; 

} 

lastUpdate = new Dated ; 
if ( currentView 1= null ,) { 
15 ' current View. updat eView( ) ; 

} 

, } • / 

// Add a single calendar to be displayed". 
20 public void addCalendar (String name) { 

addCalendar (name , true) ; 

} ' . . 

■ //Add a calendar to be displayed. If the^ calendar is 
2 5 not visible, it 

// will mark to be visible. 

protected void addCalendar (String name, boolean refresh) 

{ ' " " 

if ( i.allCalNames .contains (name) ) { 

30 allCalNames .addElement (name) ; 

} 

Mf ( IvisibleCalNames .contams.(name) ) { 
vis ibleCalNames. addElement (name) ; 

} 

35 lastUpdate = new Dated ; \ 

if ( refresh ScSc currentView != null ) { 
currentView . updateView ( ) ; 
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} ' 

) , 

// Remove a series of calendars from memory. 
3 public boolean remove Calendars (Vector vec) { 

if ( vec == null ) { 
return false; . ■ 

} " ' " 

Vector bkupVec = new Vector () ; 
for ( Enumeration enum=vec . elements () ; 
enum . hasMoreElements {) ; ) { 

String name = enum.nextElement { ) . toString ( ) ; 
if { ! removeCalendar (name , false) ) { 
addCalendars (bkupVec) ; 
15 errorMsg = "Failed to remove "+name+". 

Remove command rolled back. " ; 
calendar . showStatus (errorMsg) ; 
return false; 

■ > ) - 
20 bkupVec . addElement (name ) ; 

} . ^ 

lastUpdate = new Dated ; 
if ( cur rent View ! = null ) { 
current View. updateVi ew () ; 

25 } 

return true; 

} 



30' 
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// Remove a single calendar. 

public boolean removeCalendar (String name) { 
return removeCalendar (name , true) ; 

} 

// Remove a single calendar from the cache, 
protected boolean removeCalendar (String name, boolean 
refresh) { 

int index = allCalNames . indexOf (name) ; 
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if ( index < 0 ) { 
return false; 

} 

allCalNames . removeElementAt (index) ; ' 
5 index = visibleCalNames . indexOf (name). ; 

if ( index >= 0 ) { 

visibleCalNames . removeElementAt ( index) ; 

lastUpdate^ ='• new Dated ; 
10 if { refresh currentView != null ) .{ ' 

current View . updateView () ; 

} . 

return true; 



15 



} 



// Mark a calendar as visible and refresh the screen 
immediately. 

// If the calendar is not already loaded, it will be 
loaded as well. 
20 public boolean showCalendar (String name) { 

if ( name == null ) { 
~* return false; 

) ; : . 

if ( allCalNames .contains (name) ) { ■ - 

25 if ( ! visibleCalNames . contains (name) ) { 

visibleCalNames. addElement (name) ; 

if ( currentView ! = null ) { 

lastUpdate « new Date ( ) ; 

currentView . updateView () ; 

30 , } < 

} . , 

return true; , ' 

} . 

return . false ; ' . 

35 } 



// Mark a calendar as hidden'. Calendar data will NOT be 
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unloaded. 

public boolean hideCalendar (String name) { 
if { name == null ) { 
return false; 
* } . - 

if ( allCalNames .contains (name) ) { 
int index; 

if ( (index=visibleCalNames.indexOf (name) ) >=o ) { 

visibleCalNames.removeElementAt (index) ; 
if ( current View != null ) .{ 
lastUpdate «= new Dated ;■ 

curirentView. updateView ( ) ; 

} 

15 return true; 

] - \ 
return false; 
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} 



This invention provides a process of user interaction to 
activate a program and run it in a panel whose dimension 
and location on the screen is dynamically specified. The 
process includes three steps of user interaction: 

V. Select the window/panel based program by focusing on 
the icon and press the mouse -but ton; 

2. Move the mouse to coordinate (xl„ yl) and press" the 
mouse button; and 

3. Drag the mouse to coordinate (x2 , y2) and release the 
mouse button. 



In its embodiment, the program is running within a display 
panel. In a further embodiment, the display panel is a 
3 5 window based program. 

Our process to invoke an applet'" and let the user specify 
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the dimensions and location on screen includes three steps 
of user interaction. 

1. Select the Java program by focusing on the icon and 
5 press the mouse button. 

2. Move the mouse to coordinate (xl, yl) and press the 
mouse button . 

3. Drag the mouse to coordinate (x2, y2) and release the 
mouse button. , 
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This is a specific user interaction, sequence to invoke our 
Capplets™ or any Java applet fSee Figured) . To define the 
dimension and location for a previously selected Java 
program,- user first chooses an upper left anchor corner of 
the applet viewer (xl, yl) .by a mouse button press, 
followed by the mouse drag to the lower right corner (x2, 

Y-2) - 

Upon the user's release of the mouse button, a graphical 
panel with upper left corner of (xl, yl) and lower right 
corner of (x2, y2) is created and simultaneously the Java 
program is started within the newly created panel. The 
Java program can be an applet, a Capplet™ or simply a Java 
application. 

This invention provides- a process, to produce multimedia 
effects on a Web Calendar. We have achieved the effect of 
multimedia calendar events using Java language to implement 
the Web Calendar. 



Separating from the conventional text based calendar event 
notification, our Web Calendar achieved the multimedia and 
animated graphic event expression capability. It is 
possible now to express a calendar event in animated 
35 graphics, video with audio effects. 

' The multimedia effect process is to facilitate Multimedia 
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Java applets to be able run in the ' context of a Web 
calendar. A Java applet, by definition, is run under a 
Java enabled Web browser context (referred to as an applet 
context) and can be. programmed to produce multimedia 
5 effects. In embodiment, we use Java to implement a Web 

Calendar that, in turn, provides all the Capplets™ with 
Java enabled Web browser context '. 

Our process provides the full applet context in which 
10 multimedia capability is included, in a calendar 

environment (Refer to Figure l, 3, 5, a)'... This is 
accomplished by proliferating the applet running context 
for each cell within the calendar. Each. cell on a common 
calendar monthly, weekly, multiple days or daily grid is 
capable of running its own Capplet" instance with 
multimedia effects, concurrently with other cell's or pop- 
up window's Capplet 1 " instances. " 



15 
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See examples of multimedia calendar events cited in the 
Terminology Definition under Capplet. 



This invention provides a process that integrates 
transaction capability to scheduled events within Web 
Calendar. The process provides transaction over Internet, 
25 specifically via a Web Calendar event. \ 

The process is to associate Capplet™ that specializes in 
.Internet transaction with Web Calendar event (See Figure 
8) . It provides users with the capability to make 

30 registrations or reservations for a scheduled event, 

directly in the Web Calendar. It accomplishes a sensible 
solution for users to make commitment to- calendar events 
while surfing the net. This is a special embodiment of our 
Capplet"" and the architecture is recited in Figure 1 . For 

35 example, during the query of Lincoln Center opera 

calendars, the user can actually activate a Capplet™ that 
handles the. seating arrangement and book tickets for the 
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desired shows and, receive either rejection or confirm on 
the request . 

The Capplet™ invoked at client sites handles loading the 
5 pertinent registration * form for the desired event, 

collecting the user preference information, sends the 
information to the server and receive server -response for 
the user. 

10 The server side process of the Web Calendar event 

transaction is responsible of receiving the - registration 
•Capplet™ 1 messages, locking up resources (seats, tickets, 
classes) and making sure there's only one booking per 
resource. After completing the request, server process 

15 will send back a message indicating the status of the 

request . 

API : 
/** 

-20 The RegiServer provides a Registration service whereby 

clients can request registration forms from a Form 
database, fill them out and the server will process' 
the form and make a reservation. 

. */ 
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public class RegiServer implements Runnable. { 

protected ServerSocket sock; 
public FormDB rdb; 



public RegiServer () { 
try { 

sock = new ServerSocket (port ) ; 

, } 

35 catch . (IOException e) .{ 

System. out .printlh ( "Error Creating 
Socket exiting"); 
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. System, exit (1) ; . 

} 

// opens the form database 
rdb = new FormDB ( " FormTable " ) ; 
5 try { ' 

rdb . open ( ) ; . 

} . 

catch (Exception e) { 

System, out. printing Unable to open 
10 database") ; 

} 

run ( ) ; 

} 



All server actions are performed here. It - waits for 
connections parses "client requests and issues 
appropriate calls to the database 1 



20 + ©see RegiDB 

* ©see ClientComm 
*/ 

public void run ( ) { 



} 



/ ** 

* Clean -Up •: close the Form database 
*/ 

public void finalize () { 
30 rdb. close () ; 

} 

// This starts the registration server 
public static void main(String argv[3) { 
35 } 



/** 
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* This handles the communication on the server side 
*/ 

class ServerComm extends Thread { 
public ServerComm (Socket sock, FormDB formDb) { 
5 this, start () ; 

} ■ \ ' ■ ; 

public void run() .{ " 

} " . 

10 ' ' 

/* * 

* Registration client capplet™ 
*/ 

15 public class RegiClient extends Applet™ implements 

Conf igurableCapplet"* { 
public RegiClient {) { 

• } 

20 public RegiClient (FormID formld) { 

} . 
/** 

This function is required by the , Capplet™ interface 

2 5 + ©param event This is the event associated with 

the capplet™ 

* ©param table: Contains, name -value pairs 
containing the parameters 

* for the registration - 

30 */ 

public void initCapplet'" (CalEvent event, 

Hashtable table) { 
this, event Id = (String) event, get IndexKeyO ; 
this . eventDesc = 
35 ( String) event . get (EventKey . EVENT_NOTE) ; 

init ( ) ; 
} 
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public void initO { 

String formName = ge t Parame t e r ( 11 FORMNAME " ) 

String formOwner = getParameter ( "FORMOWNER'' } ; 

formld = new FormID (formOwner , formName); 

form = RegiConfig. getForm (formld) ; 

form. setEvent (eventld, eventDesc) ; 

setLayout (new BorderLayout ( ) ) • 

add ( "Center" , f orm) ; 

} ' 

public void start () { 
} 



public void stop () { 
15 } 

/**. 

• * Returns registration form configuration 

* panel to calendar 

20 */ 

public Panel getConf igPanel (Frame frame, 
CalEvent ev) { 

• config = new RegiConfig (user , frame); 
return config; 

25 ' } . 



/** 

* Returns configuration parameters to 

* calendar 
30 . */ 

public Hashtable getConf igParameters ( ) { 
} 

class RegiConfig extends Panel { 
35 /, 



* Constructs config panel 
*/- 
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RegiConfig (String user, Frame frame) { 
this. frame « frame; 

Panel tppPnl « new Panel (); 

5 * 

previewBtn = new Button < "Preview ..."); 
topPnl . setLayout (new 
FlowLkyout (FlowLayout . LEFT) ) ;, 
topPnl .add (new Label { " Please select a 
10 registration form: . " ) ) ; 

topPnl . add (previewBtn) ; 
cons tructFormList (user) ; 

setLayout (new BorderLayout < ) ) ; 
!5 add("North" , topPnl); 

add ( "Center" , formList); 

} 



/**. 

* Constructs form name list for selection 
*/ 

void constructFormList (String user) { 
f ormlds = getFormlDs (user) ; 
formList = new List ( ) ; 



for (int i = 0; i < f ormlds . length ; i++) { 
,if (f ormlds [i] != null) { 

System. out .print In (f ormlds [i] .getDescription*) 
f ormList .addltem(f ormlds [i] .getDescription () ) 

30 } 

} 

/* 

35 * Gets names of all forms available to user 

*/ 

- FormID[] getFormlDs (String user) { 
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ClientComm coram = new . 

ClientComm (Session. getHost () , 
Session. getPort ()) ; 

return comm. getFormList (user) • 
} ' 

* Gets registration form (object) by name 
*/ 

static RegiForm getForm (FormID id) { 
ClientComm comm = new 

ClientComm (Session. getHost () , 
Session. getPort ()) ; 

RegiForm form = null; 
15 return form; 

} - 

/**' 

f * Handles preview button 

20 */ 

public boolean action (Event evt, Object arg) { 
if (evt. target == previewBtn) 

preview ( ) ; 
return true ; 

} 

} // end of class 
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class RegiPreview extends Dialog { 

RegiPreview (Frame frame, RegiForm form) { 
// modal dialog 

super (frame, "Form Preview", true); 
Panel btnPnl = new Panel 0; 
btnPnl . setLayout (new 
35 FlowLayout (FlowLayout . CENTER) ) ; 

btnPnl . add (new Button ( "OK" )); ^ 
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add (" Center " , form) ; 
add( n South" , btnPnl) ; 

packO ; 

} . 

public boolean action (Event evt , Object arg) { 
if ( "OK" . equals (arg) ) ' 

dispose ( ) ; 
return true; 

} " - • 



* This handles the communication on the client 

* side 

public class ClientComm { 
// The protocol for the URLConnection 
// NOTE: This will need to be changed to https 

// for secure services 
public static final String protocolDef ault = "http" 

public ClientComm (String hoist, int port) { 
} 

public ClientComm (String protocol , String host, int 
port ) { 

} * . - ^ 

■./** 

* Saves the form to the form database . J The 

* end of the form contents are delimited by 

* "endForm" on a new line. 

* ©param id: The identifier of the form which 

* is to be saved to the 
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* 
* 
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* database. 

* ©param f ormContents : The content of the 

* Form as a. String 

* ©return true if the form is saved 
successfully, false if the server was 
unable to save the form or if there was a 

* communication error between server and 
* client 

* ©see FormID 

* ©see RegiForm 

*/ ' 
// It will be used by the Form database 
// administrator 

protected boolean saveForm (FormID id, String' 
15 f ormContents) { 

String key = id . toString ( )'; - 
String mesg = 

" COMMAND = PUT &ARG= " +URLEncoder . encode ( key+ 

delimiter+formContents+"\nendForm\n") • ^ 
20 try { ' 

URL target = new 

URL (protocol , host , port , cgi_script+ 
n ?"+mesg) ; 

URLConnection conn = ' . \ 

25 . target .openConnect ion () ; 

conn. setDo Input (true) ; 
DatalnputStream- in = new 
DatalnputSt ream (conn. get Input St ream () ) ; 



35 



String line = in. readLine ( ) ; 
// find the start of the response 
boolean start = false; 
while (! start) { 
/* DEBUG */ System. out. println (line) ; 

if <line==null) { 

System . out , printing "Broken 
.Connection" ) ; 
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throw new 
NullPointerException ( ) ; 

} 

else . ' 

if ( line. equals (startDelimiter) ) { 
start = true; 

} 

line = in . readLine ( ) ; 

} ' 

// read the response 

while (! line. equals (endDelimiter) ) { 

if (line . equalsIgnoreCase ( "true" ) ) { 
return true; 

} 

else 

if (line .equalsIgnoreCase ( "false" ) ) { 
return false; 

} . 

} 

return false; 

} 

catch (Exception e) { 
return false; 

} 

* * 

* Gets the id's of all the forms in the form 

* database which are accessible to the user. 

* The expected response from the server all them 
form id's seperated by 

* delimiters and the response is bounded by 
startDelimiter and endDelimiter 

* on separate lines<p> 

* i.e. startResponse\n<p> 

* idl | id2 J id3 i \n<p> 

+ endResponse\n<p> 
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* ©param The user who is requesting the form list . 

* ©return The form ids 

V. 

public FormID[] getFormList (String user) { 
^ int formCount = 0; 

String mesg = 

"COMMAND=GETALL&ARG=" +URLEncoder . encode (user+del 
imiter+ , »\n n ) ; 

try { 

URL target = new 

URL (protocol , host , port , cgi_script+ 
"?"+mesg) ; 

URLConnection conn = 
target . openConnection { ) ; 
conn. setDoInput (true) ; 
DatalnputStream in = new ' r - 

DatalnputStream (conn. get InputStreamO ) ; 

String line; 
line=in . readLine ( ) ; 



// find the start of the response 
boolean start = false; 
25 while (1 start) { 

/* DEBUG *./ System, out. print In (line) ; 

if (line==null). { 
-* System, out. print In ( "Broken 

Connection" ) ; . 
30 throw new 

NullPointerException ( ) ; 

} . 

else ' _ J 

if (line. equals (startDelimiter) ) { 
start = true; 

} 

line =_in.readLine () ; 
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} 

StringBuffer content = new 
StringBuf f er { ) ; 
5 // read the response 

while (true) { 
/* DEBUG */ System. out .print In (line) ; 

if (line == null) { 

// this. should never occur 
10 // normally 

System. out .printing "Broken 
Connection" 1 ) ; 

throw new 

NullPointerException ( ) ; 

15 } 

else if (line .equals (endDelimiter) ) { 

break; 

' } 

else { 

20 content .append (line* "\n H ); . 

} \ ' 

/* DEBUG */ System. out .print In ( "CC :"+line); 

line = in . readLine ( ) ; 



} 



25 



StringTokenizer st = new 
StringTokehizer (new 

String (content ) , 
RegiRequestHandler . delimiter) ; 
30 r int tokens = st . countTokens < ) ; 

FormID[] ret = new FormID [tokens] ; 
for (int i=0; i<tokens; i++) { 

String next = st .next Token () J ; 
System. out .print In ( "CC: 
3 5 next="+next) ; 

FormID id = new FormID (next) ; 
if (id.getOwner ( ) == null | | 
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id . getOwner ( ) . equals ( "null ".) ( | 

id. getOwner () .equals (user)) 

, { 

ret [formCount] = id; 
5 formCount++; 

- } 

} ■ ' 

return ret; 

. ) 

catch (Exception e) { 

e.printStackTrace () ; 
return null; 

} 
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This instructs the RegiServer to process a form 

* with some name-value pairs<p> 

* ^ The expected response is multiline bounded by 
20 "startRequest " and 

"endRequest" on separate lines. <p> 
©param id : The form which is to be processed 
©param event ID: The event which caused the 
registration 

25 - * ©param attr : A string which contains the ' ' 

name -value pairs for 
filling the form. 

©return The result of processing the form 



* 
* 
* 



* 

*/ 



public String request (FormID id, String eventID, 
String attr) { ' ' 



Sys tern. out .print In ("CC: REQ "+id+ ,,J 
"+eventID+" »+attr) ,- 
35 String form_id = id. toString ( ) ; 

String mesg = 

" COMMAND = REQ ficARG= " +URLEncoder . encode { f orm_id+delimiter+eve 
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ntID+delimiter+attr+delimiter+"\n M ) ; 
try { 

- URL target = new 
5 URL (protocol, host , port, cgi_script+" ? " +mesg) ; 

URLConnection conn = 

target . openConnect ion ( ) ; 
conn.setDoInput (true) ; 
DatalnputStream in « new 
10 Dat ainputSt ream (conn, get Inputs t reamO ) ; 

/* Get the single line response from 
* the server 

String buffer = in . readLine {) ; 
" return buffer; 
15 . */ _ . ~ 

// Get a multi-line response from the server 
// bounded by " startResponse" and 
"endResponse" on 
20 // separate lines 

StringBuffer content = new. 

StringBuf f er ( ) ; 
String line ~ in. readLine { ) ; 
boolean start = false; 
2 5 while ('start) { 

if (line*==null) { 

System, out .print In ( "Broken 
Connection") ; 

throw new 

3 Q NullPointerException ( ) ; 

' } 

, else if 

(line. equals (startDelimiter ) )" { 
start = true; 

line = in. readLine () ; 

System. out .print In ("CC: u +line) ; 
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} - 

while (true) {. 

if. (line == null) { 

5 System. out .print In ("Broken 

/ Connection" ) ; 
throw new 

NullPointerException () • 

} 

10 else 

if (line. equals (endDelimiter) ) {. 
break; 

} 

else { 

content . append <line+"\n") ; ■ , 

} 

line = in.readLine ( ) ; 

System. out. println ( "CC :^ "+line) ; 

} 

System, out .print In ( "CC : "+new < • 

String (content) ) ; 
return new String (content ) ; 

} 

catch (Exception e) { 
25 return null; 

} 
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What is claimed is: 

1. Capplet architecture recited in Figure 1, which can 
accommodate third-party Java applets readily and 

5 allows multiple Java programs to run simultaneously in 

a Web calendar. 

2. A process to run Java applet on a Web Calendar based 
on the architecture's openness design. 



10 



15 



20 



A process of user interaction to activate a program 
that runs in a panel, of which dimension and location 
on the screen is dynamically specified comprising 
steps of : 

a) selecting the window/panel based program by 
focusing on the icon and press the mouse button; 

b) moving the mouse to coordinate <xl, yl) and press 
the mouse button; and ' 

c) dragging the mouse to coordinate (x2, y2) and 
release the mouse button. ^ 



4. A process to achieve the viewing and editing 
capability of joint multiple calendars on the 

25 Internet. 

5. a process to produce multimedia effects on a Web 
-Calendar -by the architecture recited in Figure 1, 

using Java language to implement the Web Calendar to 
30 achieved the effect of multimedia calendar event 

contents . 

6. A process that integrates transaction " capability to 
scheduled events within Web Calendar and provides 

35 transaction over Internet. 



A process of claim 6, wherein the transaction over 
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Internet is via a Web .Calendar event. 

8. A method for multimedia information interaction with 
a user over a network which can be performed on a 
plurality of computing platforms, having an improved 
display memory - allocation control and an improved 
display space utilization, comprising the steps of- 
providing a network interface -to a network to transfer 
at least one calander base from the network organized 
according to temporal information and having an open 
object architecture; ' 
the at least one calendar base including a plurality 
of programs and a plurality of calendar events, - 
displaying the at least one calendar base; 
prbviding an event interface for associating at least 
one . of said plurality of programs with at least one of 
said plurality of calendar events; and 
providing a multimedia program interface for executing 
at least one of said plurality of programs using the 
at least one calendar base. 

9. The process of claim 8 further comprising the step of: 
providing a commerce program interface for interaction 
with electronic commerce applets. 

10. A method for multimedia information interaction with 
a user over a network in an open architecture which 
can be performed on a plurality of computing 
platforms, having an improved display . memory 
allocation control and an improved display space 
utilization, comprising the steps of: 

providing a network interface to a network to transfer 
of at least one calendar base including a plurality of 
Capplets and a plurality of calendar events; ; 
displaying the at least one calendar base organized 
according to temporal information; 

providing a plurality of icons in the at least one 
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calendar base corresponding to a plurality of views, 
each one of said plurality of views having at least 
one panel ; 

monitoring user input to select one of said plurality 
of views from said at least one /calendar base; 
modifying the at least one said calendar base to 
display the at least one panel associated with the one 
of said plurality of views selected;. 

providing a 1 Capplet interface which creates each one 
of said plurality of Capplets by interfacing a 
corresponding plurality of applets with the at least 
one calendar base; 

providing an association interface for, associating at 
least one of said plurality of Capplets with at least 
one of said plurality of calendar event; and 
providing a multimedia interface for executing at 
least one of said plurality of Capplets or at least 
one of said plurality of calendar events . 

The method of claim 10 further comprising the steps 
Of: 

providing* a first multimedia interface for the at 
least one of said plurality of panel from which a 
plurality of calendar * events or a plurality of 
Capplets can provide multimedia interaction with the 
user using the at least one calendar base; 
providing a second multimedia interface for displaying 
one of said plurality of events or at least one of 
said plurality of Capplets outside of the at least one 
panel ; 

providing an instance interface for creating Capplet 
instances by associating one of said plurality of 
Capplets with one of said plurality of calendar events 
whereby the respective Capplet of the Capplet instance 
is executed using the first multimedia interface or 
the second multimedia interface; and . 

providing an executive interface for executing, a 
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plurality of Capplets and a plurality of calendar 
events concurrently using multiple, threads. 

12. The method of claim n further comprising the step of • 
providing a plurality of calendar bases that run 
concurrently. . 

13 
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The method of claim 12 further comprising the steps 
Of: ■ , ' 

providing a data architecture such that a Capplet 
. associated with a first calendar event modifies data 
that is used by a Capplet associated with a second 
calendar event; and 

providing an interface to concurrently modify at least 
, one of said plurality Capplets or one of said 
plurality of calendar events over the network. 

14. The method of claim 13 further comprising the step of: 
providing an calendar event modification interface to 
■ monitor user input used to create, modify or delete 
^one of said plurality of said calendar events. 



15. The process of claim 11 further comprising the steps 
of: 

providing an interface in the calendar base for the 
display and selection of a calendar events from a 
plurality of calendars having at least a subset of the 
same calendar events; 

monitoring user input to select at least one of the 
calendars for display; - 
providing simultaneous display of the calendar events 
of each of the selected calendars. 

16. The process of claim li further comprising the step 
35 of: 

providing a user interface for^, the display and 
interaction with multimedia objects associated with 
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the plurality of calendar events associated with the 
plurality of panels/ 

The process of claim 11 further comprising the step 
of: 

providing a commerce Capplet^ interface for interaction 
with electronic commerce applets. 

A process to activate a program that is associated 
with an event having an improved display memory 
allocation control and an improved . display 
utilization, comprising the steps of: 

selecting an icon that is associated with the program 
on a screens- 
defining a program display dimension having a 
dimension and a location on the screen dynamically 
specified; 

the step of defining the program display dimension 
includes selecting a first coordinate (xl, yl) on the 
screen and selecting a second coordinate (x2, ,y2) on 
the screen; and 

wherein the program selected is activated when the 
second coordinate is selected. 

The process of claim 18 wherein: 

the step of selecting an icon that is associated with 
the program on the screen further comprises using a 
mouse having at least one button to locate a mouse 
pointer on the icon and pressing the mouse button and 
then releasing the mouse button; 

the step of selecting a first coordinate (xl, yl) on 
the screen further comprises moving the mouse to a 
first coordinate (xl, yl) , which is a first point used 
to define the program display dimension and location 
on .the screen, and pressing the mouse button; and' 
the step of selecting a second coordinate (x2, y2) 
further comprises dragging the mouse to the second 
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coordinate (x2, y2), while holding the mouse . button 
down, which is a second point- used to define the 
actuated program display dimension and location on 
the screen, and releasing the mouse button, whereby 
the program selected is activated using the 
dynamically defined program display dimension defined 
by the first coordinate and the second coordinate and 
location on the screen. 

A computer terminal.,' having, an improved display memory 
allocation control and an improved display 
utilization, comprising; 

a display for providing and receiving input data from 

. a user; • 

a memory for storing data, the data including the 

input data and main applet object data; 

a processor coupled to the display for providing a 

display organized using a Calendar object architecture 

in which the display is presented to the user 

according to a Calendar display in which the processor 

is coupled to the memory for storing the data; 

a user input device coupler to the processor; and 

a network interface which connects the processor to a 

network. 
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